Advanced Debugging
About AdvDbg Consult Train Services Products Tools Community Contact  
欢迎光临 高端调试 登录 | 注册 | FAQ
 
  ACPI调试
Linux内核调试
Windows内核调试
 
  调试战役
调试原理
新工具观察
 
  Linux
Windows Vista
Windows
 
  Linux驱动
WDF
WDM
 
  PCI Express
PCI/PCI-X
USB
无线通信协议
 
  64位CPU
ARM
IA-32
  CPU Info Center
 
  ACPI标准
系统认证
Desktop
服务器
 
  Embedded Linux
嵌入式开发工具
VxWorks
WinCE
嵌入式Windows
 
  格蠹调试套件(GDK)
  格蠹学院
  小朱书店
  老雷的微博
  《软件调试》
  《格蠹汇编》
  《软件调试(第二版)》
沪ICP备11027180号-1

Windows内核调试

帖子发起人: Thomson   发起时间: 2008-08-11 11:15 上午   回复: 5

Print Search
帖子排序:    
   2008-08-11, 11:15 上午
Thomson 离线,最后访问时间: 2013/3/31 11:42:42 Thomson

发帖数前10位
注册: 2008-07-03
发 贴: 211
Confused [8-)] Process monitor里面的事件是怎么得来的?
Reply Quote
Process monitor可以拿到不少event,这些event是怎么得到的呢?
是每个这样的event都有process monitor列出来的那些信息栏吗?比如Process Name,Operation,Path,Result,etc.
IP 地址: 已记录   报告
   2008-08-12, 13:24 下午
Raymond 离线,最后访问时间: 2020/7/3 3:40:25 格蠹老雷

发帖数前10位
注册: 2005-12-19
发 贴: 1,303
Re: Process monitor里面的事件是怎么得来的?
Reply Quote
Thomson,
Windows内核提供了一个名为NtQueryInformationProcess的系统服务,通过这个服务可以获取进程的各种信息,包括你说的name、path之类的。这个系统服务的部分功能以API的形式公开了,但是很多没有。
你问哪一个event呢,或者你觉得哪个功能一定要用event呢?

IP 地址: 已记录   报告
   2008-08-12, 13:28 下午
Raymond 离线,最后访问时间: 2020/7/3 3:40:25 格蠹老雷

发帖数前10位
注册: 2005-12-19
发 贴: 1,303
Re: Process monitor里面的事件是怎么得来的?
Reply Quote
下面的栈回溯显示了Process Explorer(Process Monitor的前身)在直接调用未公开的NtQueryInformationProcess系统服务:
0:005> k
ChildEBP RetAddr
02dbe0f8 00426dcb ntdll!NtQueryInformationProcess
WARNING: Stack unwind information not available. Following frames may be wrong.
02dbff54 004164b1 procexp+0x26dcb
02dbff80 0043c17e procexp+0x164b1
02dbffb4 7c80b6a3 procexp+0x3c17e
02dbffec 00000000 kernel32!BaseThreadStart+0x37

IP 地址: 已记录   报告
   2008-08-12, 19:00 下午
Thomson 离线,最后访问时间: 2013/3/31 11:42:42 Thomson

发帖数前10位
注册: 2008-07-03
发 贴: 211
Re: Process monitor里面的事件是怎么得来的?
Reply Quote
process monitor是合并了filemon和regmon的功能吧,启动它后可以capture到很多的系统event,比如下面的是一个,这个程序如果连续运行的话非常占内存,虽然有filter可以去掉很多event,但是我怀疑是不是所有的event都cache,所以占内存. 我想知道一下程序怎么实现在,看了一下import的方法里面,好像没有ETW的相关的方法.
97377 6:55:10.8373073 PM LoadLibrary.exe 5300 Load Image D:\Project\LoadLibrary\Debug\LibraryDll.dll SUCCESS Image Base: 0x10000000, Image Size: 0x1b000
这里是下载地址:
http://live.sysinternals.com/Procmon.exe

IP 地址: 已记录   报告
   2008-08-12, 22:51 下午
Raymond 离线,最后访问时间: 2020/7/3 3:40:25 格蠹老雷

发帖数前10位
注册: 2005-12-19
发 贴: 1,303
Re: Process monitor里面的事件是怎么得来的?
Reply Quote
Filemon和regmon都曾经开源,在Vista之前使用的是hook内核函数的方法。在Vista中,系统特意留了接口以避免不规范的hook方法。
Procmon中的进程和线程活动事件(除了Regmon、Filemon之外的第三个功能),应该是通过NKL来实现的(至少可以这么做),即《软件调试》16.7节介绍的内容,注意图16-4。
IP 地址: 已记录   报告
   2008-08-13, 13:03 下午
WANGyu 离线,最后访问时间: 2012/9/10 3:34:00 王宇

发帖数前10位
男
注册: 2007-05-08
发 贴: 306
Re: Process monitor里面的事件是怎么得来的?
Reply Quote
也真“难为”微软了,一直试图把内核程序员们往正道上引... ;)
IP 地址: 已记录   报告
高端调试 » 软件调试 » Windows内核调试 » Process monitor里面的事件是怎么得来的?

 
Legal Notice Privacy Statement Corporate Governance Corporate Governance
(C)2004-2020 ADVDBG.ORG All Rights Reserved.